Namespaces
Variants

std::literals::string_view_literals:: operator""sv

From cppreference.net
헤더에 정의됨 <string_view>
constexpr std:: string_view
operator "" sv ( const char * str, std:: size_t len ) noexcept ;
(1) (C++17부터)
constexpr std:: u8string_view
operator "" sv ( const char8_t * str, std:: size_t len ) noexcept ;
(2) (C++20부터)
constexpr std:: u16string_view
operator "" sv ( const char16_t * str, std:: size_t len ) noexcept ;
(3) (C++17부터)
constexpr std:: u32string_view
operator "" sv ( const char32_t * str, std:: size_t len ) noexcept ;
(4) (C++17부터)
constexpr std:: wstring_view
operator "" sv ( const wchar_t * str, std:: size_t len ) noexcept ;
(5) (C++17부터)

문자 리터럴의 문자열 뷰를 형성합니다.

1) 반환값 std:: string_view { str, len } .
2) 반환값 std:: u8string_view { str, len } .
3) 반환값 std:: u16string_view { str, len } .
4) 반환값 std:: u32string_view { str, len } .
5) 반환값 std:: wstring_view { str, len } .

목차

매개변수

str - 원시 문자 배열 리터럴의 시작을 가리키는 포인터
len - 원시 문자 배열 리터럴의 길이

반환값

std::basic_string_view 리터럴.

참고 사항

이 연산자들은 네임스페이스 std::literals::string_view_literals 에서 선언되며, 여기서 literals string_view_literals 는 모두 인라인 네임스페이스입니다. 이 연산자들에 접근하려면 다음 중 하나를 사용하면 됩니다:

  • using namespace std :: literals ,
  • using namespace std :: string_view_literals , 또는
  • using namespace std :: literals :: string_view_literals .

예제

#include <iostream>
#include <string_view>
#include <typeinfo>
void print_each_character(const std::string_view sw)
{
    for (char c : sw)
        std::cout << (c == '\0' ? '@' : c);
    std::cout << '\n';
}
int main()
{
    using namespace std::literals;
    std::string_view s1 = "abc\0\0def";
    std::string_view s2 = "abc\0\0def"sv;
    std::cout << "s1.size(): " << s1.size() << "; s1: ";
    print_each_character(s1);
    std::cout << "s2.size(): " << s2.size() << "; s2: ";
    print_each_character(s2);
    std::cout << "substr(1, 4): " << "abcdef"sv.substr(1, 4) << '\n';
    auto value_type_info = []<typename T>(T)
    {
        using V = typename T::value_type;
        std::cout << "sizeof " << typeid(V).name() << ": " << sizeof(V) << '\n';
    };
    value_type_info("char A"sv);
    value_type_info(L"wchar_t ∀"sv);
    value_type_info(u8"char8_t ∆"sv);
    value_type_info(u"char16_t ∇"sv);
    value_type_info(U"char32_t ∃"sv);
    value_type_info(LR"(raw ⊞)"sv);
}

가능한 출력:

s1.size(): 3; s1: abc
s2.size(): 8; s2: abc@@def
substr(1, 4): bcde
sizeof char: 1
sizeof wchar_t: 4
sizeof char8_t: 1
sizeof char16_t: 2
sizeof char32_t: 4
sizeof wchar_t: 4

참고 항목

basic_string_view 를 생성합니다
(public member function)
문자 배열 리터럴을 basic_string 으로 변환합니다
(function)